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IN THE CLAIMS 



LISTING OF CLAIMS: 

1 . (Currently amended) In a transferring node, a method for distributing data 
in an overlay network based on logical relationships, said overlay network 
including i n-a hierarchical network of nodes , said overlay network 
implemented as an abstraction on top of an existing network based on 
other connections , the method comprising the steps of: 

receiving at the transferring node a collection of data from a 
provider node in the hierarchical network of nodes; 

transferring a copy of the collection of data to a child node of the 
transferring node in the hierarchical network of nodes in response to the 
step of receiving the collection of data; and 

storing the collection of data in a data storage in the transferring 
node after completing the step of transferring the copy of the collection of 
data. 



2. (Original) The method of claim 1 , wherein the collection of data 

represents content distributed as a stream of packets to the hierarchical 
network from a source node, and wherein: 

the step of receiving the collection of data comprises receiving the 
stream of packets in a buffer; 

the step of transferring the copy of the collection of data comprises 
propagating the stream of packets from the buffer to descendent nodes of 
the transferring node for access by a first client making a first request for 
the collection of data from the descendent node; and 

the step of storing the collection of data comprises transferring the 
stream of packets from the buffer to the data storage in the transferring 
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node in a manner enabling access to the collection of data by a second 
client making a second request for the collection of data. 

3. (Original) The method.of claim 1 , wherein the child node is one of a 
plurality of child nodes, and the step of transferring the copy of the 
collection of data comprises transferring copies of the collection of data to 
each of the plurality of child nodes, if each child node is available over the 
hierarchical network. 

4. (Original) The method of claim 1 , wherein the step of transferring the 
collection of data comprises receiving a verification from the child node 
that the copy of the collection of data received by the child node is a 
complete copy of the collection of data. 

5. (Original) The method of claim 1 , wherein the collection of data comprises 
a plurality of packets of data and the step of transferring the copy of the 
collection of data comprises: 

(i) receiving an indication from the child node that the copy of 
the collection of data received by the child node is incomplete; and 

(ii) transferring copies of at least one packet of data to the 
child node to complete the copy of the collection of data received 
by the child node. 

6. (Original) The method of claim 1 , wherein the step of transferring the copy 
of the collection of data comprises transferring an additional copy of the 
collection of data to an additional child node of the transferring node 
based on a request from the additional child node. 

7. (Original) The method of claim 1 , wherein the step of transferring the copy 
of the collection of data comprises transferring the copy of the collection of 
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data between the provider node and the child node through the 
transferring node in a delayed timing mode. 

8. (Original) The method of claim 1 , wherein the step of storing the collection 
of data comprises retaining the collection of data after confirming the 
receipt of the copy of the collection of data by the child node. 

9. (Original) The method of claim 1, wherein the step of receiving the 
collection of data comprises a step of providing an acknowledgment 
indicating that the collection of data is complete and the step of 
transferring the collection of data is performed after the step of providing 
the acknowledgment. 

10. (Original) The method of claim 1, further comprising the step of: 

Maintaining a connection among the network of nodes in order to 
transfer the collection of data. 

1 1 . (Currently amended) A computer system for distributing data in an 
overlay network based on logical relationships, said overlay network 
including a-an hierarchical network of nodes, said overlay network 
implemented as a network abstraction on top off an existing network 
based on other connections, the computer system comprising: 

a memory; 
a data storage; 

a network interface in communication with the memory and the data 
storage; and 

a processor in communication with the memory, the data storage, 
and the network interface, 

wherein the memory is encoded with logic instructions for a data 
manager application that, when performed on the, processor, cause the 
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processor to form a data manager that manages the distribution of data in 
the hierarchical network by performing operations of: 

receiving a collection of data at a transferring node from a 
provider node in the hierarchical network of nodes; 

transferring a copy of the collection of data to a child node of 
the transferring node in the hierarchical network of nodes in 
response to the step of receiving the collection of data; and 
storing the collection of data in a data storage at the 
transferring node after completing the transferring of the copy of the 
collection of data. 

12. (Original) The computer system of claim 1 1 , further comprising a buffer, 
wherein the collection of data represents content distributed a stream of 
packets to the hierarchical network from a source node and the logic 
instructions for the data manager application comprise further logic 
instructions, that, when performed on the processor, cause the data 
manager to perform operations of: 

receiving the stream of packets in the buffer; 

propagating the stream of packets from the buffer to descendent 
nodes of the transferring node for access by a first client making a first 
request for the collection of data from the descendent node; and 

transferring the stream of packets from the buffer to the data 
storage in the transferring node in a manner enabling access to the 
collection of data by a second client making a second request for the 
collection of data. 

13. (Original) The computer system of claim 1 1 , wherein the child node is one 
of a plurality of child nodes, and the logic instructions for the data manager 
application comprise further logic instructions, that, when performed on 
the processor, cause the data manager to perform an operation of 
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transferring copies of the collection of data to each of the plurality of child 
nodes, if each child node is available over the hierarchical network. 

14. (Original) The computer system of claim 1 1 , wherein the logic instructions 
for the data manager application comprise further logic instructions, that, 
when performed on the processor, cause the data manager to perform an 
operation of receiving a verification from the child node that the copy of 
the collection of data received by the child node is a complete copy of the 
collection of data. 

1 5. (Original) The computer system of claim 1 1 , wherein the collection of data 
comprises a plurality of packets of data and the logic instructions for the 
data manager application comprise further logic instructions, that, when 
performed on the processor, cause the data manager to perform 
operations of: 

(i) receiving an indication from the child node that the copy of 
the collection of data received by the child node is incomplete; and 

(ii) transferring copies of at least one packet of data to the 
child node to complete the copy of the collection of data received 
by the child node. 

16. (Original) The computer system of claim 1 1 , wherein the logic instructions 
for the data manager application comprise further logic instructions, that, 
when performed on the processor, cause the data manager to perform an 
operation of transferring an additional copy of the collection of data to an 
additional child node of the transferring node based on a request from the 
additional child node. 

17. (Original) The computer system of claim 1 1 , wherein the logic instructions 
for the data manager application comprise further logic instructions, that, 
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when performed on the processor, cause the data manager to perform an 
operation of transferring the copy of the collection of data between the 
provider node and the child node through the transferring node in a 
delayed timing mode. 

1 8. (Original) The computer system of claim 1 1 , wherein the logic instructions 
for the data manager application comprise further logic instructions, that, 
when performed on the processor, cause the data manager to perform an 
operation of retaining the collection of data after confirming the receipt of 
the copy of the collection of data by the child node. 

19. (Original) The computer system of claim 1 1 , wherein the logic instructions 
for the data manager application comprise further logic instructions, that, 
when performed on the processor, cause the data manager to perform an 
operation of transferring the collection of data after providing an 
acknowledgment indicating that the collection of data is complete. 

20. (Currently amended) A computer program product that includes a 
computer readable medium having instructions stored thereon for 
distributing data in an overlay network based on logical relationships, said 
overlay network including a-an hierarchical network, the overlay network 
implemented as a network abstraction on top of an existing network based 
on other connections, such that the instructions, when carried out by a 
computer, cause the computer to perform steps of: 

receiving a collection of data at a transferring node from a provider 
node in the hierarchical network of nodes; 

transferring a copy of the collection of data to a child node of the 
transferring node in the hierarchical network of nodes in response to the 
step of receiving the collection of data; and 

storing the collection of data in a data storage at the transferring 
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node after completing the step of transferring the copy of the collection of 
data. 

21 . (Currently amended) A computer system for distributing data in an 
overlay network based on logical relationships, said overlay network 
including a-an hierarchical network of nodes , the overlay network 
implemented as a network abstraction on top off an existing network 
based on other connections , the computer system comprising: 

means for receiving a collection of data at a transferring node from 
a provider node in the hierarchical network of nodes; 

means for transferring a copy of the collection of data to a child 
node of the transferring node in the hierarchical network of nodes in 
response to the step of receiving the collection of data; and 

means for storing the collection of data in a data storage at the 
transferring node after completing the step of transferring the copy of the 
collection of data. 

22. (Previously Presented) The method of claim 1 further comprising allowing 
access to the collection of data in the data storage at the transferring node 
at a later time by at least one of the child node and another node. 

23. (Previously Presented) The method of claim 1 wherein the step of 
receiving the collection of data from the provider node includes the step of 
obtaining a multicast video stream and buffering a version of the multicast 
video stream completely in volatile memory; 

wherein the step of transferring the copy of the collection of data 
includes the step of reading the buffered version of the multicast video 
stream from the volatile memory and sending that buffered version of the 
multicast video stream to the child node; 
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wherein the step of storing the collection of data in the data storage 
includes the step of, in response to completing transfer of the buffered 
version of the multicast video stream to the child node, saving a copy of 
the buffered version of the multicast video stream in non-volatile memory; 
and 

wherein the method further comprises the steps of (i) acquiring a 
request for the data from a requesting node at a later time, (ii) retrieving 
the saved copy of the buffered version of the multicast video stream from 
the non-volatile memory, and (iii) sending the saved copy to the 
requesting node. 

24. (Previously Presented) The computer system of claim 1 1 wherein the 
memory is encoded with logic instructions for a data manager application 
that, when performed on the processor, cause the processor to form a 
data manager that manages the distribution of data in the hierarchical 
network by performing operations of: 

allowing access to the collection of data in the data storage at the 
transferring node at a later time by at least one of the child node and 
another node. 

25. (Previously Presented) The computer system of claim 1 1 wherein the 
memory is encoded with logic instructions for a data manager application 
that, when performed on the processor, cause the processor to form a 
data manager that manages the distribution of data in the hierarchical 
network by performing operations of: 

wherein the step of receiving the collection of data from the 
provider node includes the step of obtaining a multicast video stream and 
buffering a version of the multicast video stream completely in volatile 
memory; 
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wherein the step of transferring the copy of the collection of data 
includes the step of reading the buffered version of the multicast video 
stream from the volatile memory and sending that buffered version of the 
multicast video stream to the child node; 

wherein the step of storing the collection of data in the data storage 
includes the step of, in response to completing transfer of the buffered 
version of the multicast video stream to the child node, saving a copy of 
the buffered version of the multicast video stream in non-volatile memory; 
and 

wherein the method further comprises the steps of (i) acquiring a 
request for the data from a requesting node at a later time, (ii) retrieving 
the saved copy of the buffered version of the multicast video stream from 
the non-volatile memory, and (iii) sending the saved copy to the 
requesting node. 

26. (Previously Presented) The computer program product of claim 20 further 
comprising: 

instructions wherein the step of receiving the collection of data from 
the provider node includes the step of obtaining a multicast video stream 
and buffering a version of the multicast video stream completely in volatile 
memory; 

instructions wherein the step of transferring the copy of the 
collection of data includes the step of reading the buffered version of the 
multicast video stream from the volatile memory and sending that buffered 
version of the multicast video stream to the child node; 

instructions wherein the step of storing the collection of data in the 
data storage includes the step of, in response to completing transfer of the 
buffered version of the multicast video stream to the child node, saving a 
copy of the buffered version of the multicast video stream in non-volatile 
memory; and 
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instructions wherein the method further comprises the steps of (i) 
acquiring a request for the data from a requesting node at a later time, (ii) 
retrieving the saved copy of the buffered version of the multicast video 
stream from the non-volatile memory, and (iii) sending the saved copy to 
the requesting node. 

27. (New) The transferring node of claim 1 wherein said hierarchical network 
of nodes comprise a distribution tree. 

28. (New) The transferring node of claim 27 wherein said distribution tree is 
rooted at a source node, said source node comprising said transferring node. 

29. (New) The computer system of claim 1 1 wherein said hierarchical network 
of nodes comprise a distribution tree. 

30. (New) The computer system of claim 29 wherein said distribution tree is 
rooted at a source node, said source node comprising said transferring node. 

31 . (New) The computer program product of claim 20 wherein said 
hierarchical network of nodes comprise a distribution tree. 

32. (New) The computer program product of claim 31 wherein said distribution 
tree is rooted at a source node, said source node comprising said transferring 
node. 

33. (New) The computer system of claim 21 wherein said hierarchical network 
of nodes comprise a distribution tree. 

34. (New) The computer system of claim 33 wherein said distribution tree is 
rooted at a source node said source node comprising said transferring node. 



